package org.example.config;

/**
 * @Title: RpcConfig
 * @Author: kunliangzhao
 * @Package org.example.config
 * @Date: 2025/6/9 10:14
 * @Description: 配置类
 */

import lombok.Data;
import org.example.fault.retry.RetryStrategyKeys;
import org.example.fault.tolerant.TolerantStrategyKeys;
import org.example.loadbalancer.LoadBalancerKeys;
import org.example.serializer.SerializerKeys;

/**
 * RPC 框架配置
 */
@Data
public class RpcConfig {

    /**
     * 名称
     */
    private String name = "zkl-rpc";

    /**
     * 版本号
     */
    private String version = "1.0";

    /**
     * 服务器主机名
     */
    private String serverHost = "localhost";

    /**
     * 服务器端口号
     */
    private Integer serverPort = 8080;

    /**
     * 模拟调用
     */
    private boolean mock = false;

    /**
     * 序列化方式
     */
    private String serializer = SerializerKeys.JDK;

    /**
     * 注册中心配置
     */
    private RegistryConfig registryConfig = new RegistryConfig()    ;


    /**
     * 负载均衡方式
     */
    private String loadBalancer = LoadBalancerKeys.RANDOM;

    /**
     * 重试策略
     */
    private String retryStrategy = RetryStrategyKeys.NO;


    /**
     * 容错策略
     */
    private String tolerantStrategy = TolerantStrategyKeys.FAIL_FAST;

}
